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l. 

(a) 
(b) 

13) 

(c) 
(d) 



2. 

3. 

4. 
5. 

6. 

7. 

£2 8. 



amend claims 1,8, 13, 20, 25, 29, and 32 as follows: * 

(Amended) A method for programmable processing in a computer graphics 

pipeline, comprising: / 

receiving data from a [source] buffer; / 

performing programmable operations on the data iiyorder to generate output, 

wherein the operations are programmable by a user utilizing instructions 

from a predetermined instruction set; / 

storing the output in [a register] memory ; anp 

wherein the output stored in the [register] memory is used in performing the 
programmable operations on the data. / 



The method as recited inVcmim 1, wherein only one vertex is processed at a 
time. / / 

The method as recited in claim /, wherein operations (a)-(d) are processed 
for multiple vertexes in parallel. 

The method as recited in claim 1, wherein the data includes a constant. 

The method as recited in claim 4, wherein the constant is stored in a constant 
source buffer. / 

The method as recited in claim 5, wherein the constant is accessed in the 
constant source buffer using an absolute or relative address. 

The method as recited in claim 1, wherein the data includes vertex data. 

(Amended) The method as recited in claim 1, wherein the [register] memory 
has single write and triple read access. 
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9. The method as recited in claim 1, and further comprising storing tne output 
in a destination buffer. / 

10. The method as recited in claim 9, wherein the output is stored in the 
destination buffer under a predetermined reserved address. 

1 1 . The method as recited in claim 1, and further composing negating the data. 

12. The method as recited in claim 1, and further comprising swizzling the data. 

1 3 . (Amended) A computer program embodied'on a computer readable medium 
for programmable proOTssirfg in a computer graphics pipeline, comprising: 

(a) a code segment for receding data fronya [source] buffer; 

(b) a code segment for performing programmable operations on the data in order 
to generate output, wherein the ope/ations are programmable by a user 
utilizing instructions from a predetermined instruction set; 

(c) a code segment for storing the cwtput in [a register] memory ; and 

(d) wherein the output stored in me [register] memory is used in performing the 
programmable operations o/ the data. 

14. The computer program afs recited in claim 13, wherein only one vertex is 
processed at a time. / 

15. The computer program as recited in claim 13, wherein the code segments are 
executed for multiple vertexes in parallel. 

16. The compute/program as recited in claim 13, wherein the data includes a 
constant. / 

17. The computer program as recited in claim 16, wherein the constant is stored 
in a constant source buffer. 
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18. The computer program as recited in claim 1 7, wherein the constant/fs 
accessed in the constant source buffer using an absolute or relative address. 

1 9. The computer program as recited in claim 13, wherein the dsfta includes 
vertex data. / 

20. (Amended) The computer program as recited in clainvl 3, wherein the 
[register] memory has single write and triple read aofcess. 

2 1 . The computer program/as recited in claim 1 3, apd further comprising a code 
segment for storing me output in a destination buffer. 

22. The computer program as/recited in clainv21 , wherein the output is stored in 
the destination bufferxipfler a predetemnned reserved address. 

23. The computer program as recited in/claim 13, and further comprising a code 
segment for negating the data. / 

24. The computer program as recited in claim 13, and further comprising a code 
segment for swizzling the data. 

25. (Amended) A system for programmable vertex processing, comprising: 

(a) a [source] buffer for storing data; 

(b) a functional module /oupled to the [source] buffer for performing 
programmable operations on the data received therefrom in order to generate 
output, wherein me operations are programmable by a user utilizing 
instructions from a predetermined instruction set; and 

(c) [a register] memory coupled to the functional module for storing the output 
such that the output may be used by the functional module in performing the 
programmable operations on the data. 



26. A method for performing an operation on data in a computer graphics 
pipeline, comprising: 
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(a) 

(b) 

(c) 

(d) 
(e) 

(f) 

(g) 



receiving a source location identifier indicating a source location of data to 
be processed, wherein the source location includes a plurality of 
components; 

receiving a source component identifier indicating in whichr of the plurality 
of components of the source location the data resides; 
retrieving the data based on the source location identifier and the source 
component identifier; 

performing an operation on the retrieved data in older to generate output; 
identifying a destination location identifier indicating a destination location 
of the output, wherein ther destination locatioiwicludes a plurality of 
components; \ / 

identifying a destination /omponent identi^ er indicating in which of the 
plurality of components ©f the destinaticjp location the output is to be stored; 
and \] 

storing the output based on the destiijation location identifier and the 
destination component identifier. 



27. The computer program as recited in claim 26, wherein the operation is 

selected from the group consisting of a no operation, address register load, 
move, multiply, addition, multiply and addition, reciprocal, reciprocal square 
root, three component dot product, four component dot product, distance 
vector, minimum, maximum, set on less than, set on greater or equal than, 
exponential base two (2/J, logarithm base two (2), and/or light coefficients. 



28. A computer-readable medium containing a data structure for performing an 
operation on data in a computer graphics pipeline, comprising: 

(a) a source location /dentifier indicating a source location of data to be 
processed, wherein the source location includes a plurality of components; 

(b) a source component identifier indicating in which of the plurality of 
components pf the source location the data resides, wherein the data is 
retrieved based on the source location identifier and the source component 
identifier Aor performing an operation on the retrieved data in order to 
generate output; 



NVTOP021/P000174 



-6- 



(c) a destination location identifier indicating a destination location of A 
output, wherein the destination location includes a plurality of components; 
and 

(d) a destination component identifier indicating in which of th^ plurality of 
components of the destination location the output is to be/stored, wherein the 
output is stored based on the destination location identifier and the 
destination component identifier. 



(a) 
(b) 

(c) 



(d) 



30. 



(Amen 




fta; 



able operations pn the graphics data in order to 
s determined thM the graphics pipeline is operating in 



29. (Amended) A method for programmable processing in a computer graphics 
pipeline, comprising: 
receiving graphics < 

determining wh§lner ; the graphics pipelines operating in a programmable 
mode; \ 
performing pro\ 
generate outpu^^ 

the programmab|e mode, wherehyhe operations are programmable by a user 
utilizing instructions from a predetermined instruction set which is different 
from [an instruction^ of] a standard graphics application program interface 
in order to provide increased/flexibility in programming the processing in the 
computer graphics pipeline? and 

performing operations on/the graphics data in order to generate output m 
accordance with the standard graphics application program interface if it is 



determined that the graphics^pipeline is not operating in the programmable 
mode in order to [preserve] enable hardware optimization afforded by the 
standard graphics^tpplication prit^gram interface. 

The method a^recited in claim 29, wherein the standard graphics application 
program interface includes OpenGL . 



3 1 . The method as recited in claim 29, wherein the graphics data includes vertex 
data. 
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32. (Amended) A computer program embodied on a computer readable medium 
for programmable processing in a computer graphics pipeline, comprising: 

(a) a code segment for receiving graphics data; 

(b) a code segment for determining whether the graphics pipeline is operating in 
a programmable mode; 

(c) a code segment rbr performing programmable operations on the graphics 
data in order to generate output if it is determined that the graphics pipeline 
is operating in the programmable mode, wherein the operations are 
programmable by a user utilizing instructions from a predetermined 
instruction set which is (different from [an instruction set of] a standard 
graphics application program interface in order to provide increased 
flexibility in programming ^e processing in the computer graphics pipeline; 
and 

(d) a code segment for performingY>perations on the graphics data in order to 
generate output in accordance with the standard graphics application 
program interface if it is determined that the graphics pipeline is not 
operating in the programmable modeL in order to [preserve] enable hardware 
optimization afforded by the standard graphics application program interface. 



33. 

(a) 
(b) 

(c) 



The method as recited in claim 29, wjferein the programmable operations are 
performed using a system comprising: 
a source buffer /ox storing the graphics data; 
a functional niodiile couplejno the source buffer for performing the 
programmabie'operation)/ m the graphics data received therefrom in order to 
generate the otftput; ajrcl 

a register coupled to the functional module for storing the output such that 
the output may be used by the functional module in performing the 
programmable^ operations on the graphics data. 



34. The metho/a as recited in claim 29, wherein the programmable operations are 
perfonryed using a data structure comprising: 



NVTOP021/P000174 



• # 

-8- 



(a) a source location identifier indicating a source location of tne graphics data 
to be processed, wherein the source location includes a jjourality of 
components; 

(b) a source component identifier indicating in which of the plurality of 
components of the source location the graphics dafia resides, wherein the 
graphics data is retrieved based on the source location identifier and the 
source component identifier for performing ajl operation on the retrieved 
graphics data in order to generate the output 

(c) a destination location identifier indicating a destination location of the 
output, wherein the destination location jncludes a plurality of components; 
and 

(d) a destination compbneAfcdentifier indicating in which of the plurality of 
components of the destination location the output is to be stored, wherein the 
output is stored based on the destination location identifier and the 
destination component identifier. 




35. The method as recited in clainy29, wherein the instructions from the 
predetermined instruction set/are selected from the group consisting of a no 
operation, address register load, move, multiply, addition, multiply and 
addition, reciprocal, reciprocal square root, three component dot product, 
four component dot product, distance vector, minimum, maximum, set on 
less than, set on greater or equal than, exponential base two (2), logarithm 
base two (2), and/or limit coefficients. 

36. The computer program as recited in claim 32, wherein the programmable 
operations are performed using a system comprising: 

(a) a source buffer for storing the graphics data; 

(b) a functional moaule coupled to the source buffer for performing the 
programmableAperations on the graphics data received therefrom in order to 
generate the output; and 

(c) a register cmipled to the functional module for storing the output such that 
the outpuwnay be used by the functional module in performing the 
programmable operations on the graphics data. 

NVTOP021/P000174 



